/***************************************************************************/
/* Procedimiento: bdUsuariosInsertar
/* Descripcion:   Insertar o Modifica una fila en la tabla Usuarios
/* Parametros:    ?InfoParametros
/*                pTransaccion. Numero identificador de la Transaccion
/*                pMensaje. Mensaje de comfirmacion o excepcion
/* Comentarios:         
/****************************************************************************/

PROCEDURE bdUsuariosInsertarModificar(pclave VARCHAR2, pnombre VARCHAR2, pemail VARCHAR2, 
								pfechaalta VARCHAR2, pfechaultacc VARCHAR2, psuperusu NUMBER, 
								pactivo NUMBER, ptipousu VARCHAR2,  pTransaccion OUT NUMBER, pMensaje OUT VARCHAR2)
AS
vExisteRegistro NUMBER(1);
BEGIN
  SELECT count(*)
  INTO   vExisteRegistro
  FROM   Usuarios
  WHERE  nidDocumento=pNidDocumento;
  
  IF vExisteRegistro=0 THEN
    INSERT INTO Usuarios
	           (usuario, clave, nombre, 
				email, fechaalta, fechaultacc, 
				superusu, activo, tipousu)
    VALUES     (seq_Usuarios.nextval, pclave, pnombre, 
				pemail, to_date(pfechaalta,'DD/MM/YYYY HH24:MI:SS'), to_date(pfechaultacc,'DD/MM/YYYY HH24:MI:SS'), 
				psuperusu, pactivo, ptipousu);
  ELSE
    UPDATE Usuarios
    SET    clave=pclave, nombre=pnombre, 
			email=pemail, fechaalta=to_date(pfechaalta,'DD/MM/YYYY HH24:MI:SS'), fechaultacc=to_date(pfechaultacc,'DD/MM/YYYY HH24:MI:SS'), 
			superusu=psuperusu, activo=pactivo, tipousu=ptipousu
    WHERE  nidDocumento=pNidDocumento;
  END IF;
  
  COMMIT;
  pTransaccion := 1;
  pMensaje := 'Terminado OK';
  dbms_output.put_line('Terminado OK');

EXCEPTION
  WHEN OTHERS THEN
    pTransaccion := 0;
    pMensaje := 'Error en bdUsuarios_InsertarModificar:' || SQLCODE || ' Mensaje: ' || sqlerrm;
    dbms_output.put_line('Error en bdUsuarios_InsertarModificar:' || SQLCODE || ' Mensaje: ' || sqlerrm);
END;
